import axios from 'axios'
import { get } from 'lodash'
import util from '@/libs/util'
import { errorLog, errorCreate } from './tools'

/**
 * @description 创建请求实例
 */
function createService() {
  // 创建一个 axios 实例
  const service = axios.create()
  // 请求拦截
  service.interceptors.request.use(
    config => config,
    error => {
      // 发送失败
      // console.log(error)
      return Promise.reject(error)
    }
  )
  // 响应拦截
  service.interceptors.response.use(
    response => {
      // dataAxios 是 axios 返回数据中的 data
      const dataAxios = response.data
      // 这个状态码是和后端约定的
      const { success } = dataAxios
      // 根据 code 进行判断
      if (success === undefined) {
        // 如果没有 code 代表这不是项目后端开发的接口 比如可能是 D2Admin 请求最新版本
        return dataAxios
      } else {
        // 有 code 代表这是一个后端接口 可以进行进一步的判断
        if (success) {
          return dataAxios.result;
        } else {
          errorCreate(`调用服务返回异常 ${dataAxios.msg}: ${response.config.url}`)
        }
      }
    },
    error => {
      const status = get(error, 'response.status')
      switch (status) {
        case 400: error.message = '请求错误'; break
        case 401: error.message = '未授权，请登录'; break
        case 403: error.message = '拒绝访问'; break
        case 404: error.message = `请求地址出错: ${error.response.config.url}`; break
        case 408: error.message = '请求超时'; break
        case 500: error.message = '服务器内部错误'; break
        case 501: error.message = '服务未实现'; break
        case 502: error.message = '网关错误'; break
        case 503: error.message = '服务不可用'; break
        case 504: error.message = '网关超时'; break
        case 505: error.message = 'HTTP版本不受支持'; break
        default:
          if (error.response == undefined) {
            error.message = '无法连接到远程服务器';
          }
          break
      }
      errorLog(error)
      return Promise.reject(error)
    }
  )
  return service
}

/**
 * @description 创建请求方法
 * @param {Object} service axios 实例
 */
function createRequestFunction(service,type) {
  return function (methodName, args = {}) {
    const token = util.cookies.get('token')
    const userName = util.cookies.get('userName')
    var uiArgs = {
      token: token,
      userName: userName,
      methodName: methodName,
      type: type,
      methodArgs: args
    };
    const configDefault = {
      headers: {
        'Content-Type': 'application/json; charset=utf-8'
      },
      maxContentLength:10485760,
      timeout: 5000,
      method:'POST',
      url: process.env.VUE_APP_API,
      data: uiArgs
    }
    return service(configDefault)
  }
}

// 用于真实网络请求的实例和请求方法
export const service = createService()
export const request = createRequestFunction(service,'IWebAPIExecute')

// 用于模拟网络请求的实例和请求方法
// export const serviceForMock = createService()
// export const requestForMock = createRequestFunction(serviceForMock)

// 网络请求数据模拟工具
// export const mock = new Adapter(serviceForMock)
